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FIELD OF THE INVENTION 

[0001] The present invention generally relates to circuit 
simulation, and more particularly to simulating a circuit at the 
programmable logic device level. 

BACKGROUND 

[0002] Usage of programmable logic devices (PLDs) , in 
particular, field programmable gate arrays (FPGAs) , is expanding 
from implementation of static circuit designs to in-system, 
runtime reconfiguration applications. For runtime 
reconfiguration applications to proliferate, designers must have 
access to tools that support the development of such 
applications. For example, JBits software from Xilinx provides 
an environment for designing and deploying applications that 
support runtime reconfiguration. 

[0003] A full complement of tools in a development environment 
includes a simulator for simulating operation of the circuit on a 
computer. While there are many simulators available for 
simulating a static circuit design, the simulators are generally 
unsuitable for simulating a runtime reconf igurable design. Since 
simulators are built to simulate static circuit designs, runtime 
changes to a design (such as those that occur in a runtime 
reconf igurable design) cannot be simulated. 

[0004] A system and method that address the aforementioned 
problems, as well as other related problems, are therefore 
desirable . 

SUMMARY OF THE INVENTION 

[0005] In various embodiments, a method and system are 
provided for simulating a circuit design for a programmable logic 
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device (PLD) at the device level. The same configuration data 
that is used to configure a PLD is used to generate objects that 
represent configurable logic elements of the PLD . During 
simulation, events are generated based on changes in output 
signal states of the objects. Each event includes an input 
signal state and identifies an object to which the input signal 
is to be applied. Events are processed by updating attributes of 
the objects. If an event causes a change in the output signal 
state of an object ("current object"), the configurable logic 
elements that are connected ("output-connected") to the 
configurable logic element of the current object are identified, 
and events are generated for each of the objects associated with 
the output-connected configurable logic elements. 
[0006] Since configurable logic elements are simulated, for 
example, lookup tables, instead of logic gates, fewer events need 
to be generated and processed than in a conventional simulator. 
In another embodiment, the system supports an interface that 
allows tools to interface with the simulator in the same manner 
as the tools interface with a PLD. 

[0007] It will be appreciated that various other embodiments 
are set forth in the Detailed Description and Claims which 
follow. 

BRIEF DESCRIPTION OF THE DRAWINGS 

[0008] Various aspects and advantages of the invention will 
become apparent upon review of the following detailed description 
and upon reference to the drawings in which: 

[0009] FIG. 1 is a functional block diagram that illustrates 
the functional relationship between a simulator and other tools 
in a conventional circuit design path; 

[0010] FIG. 2 is a functional block diagram that illustrates a 
device simulator in combination with an environment for runtime 
reconf igurable PLD circuit designs; 
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[0011] FIGs. 3A and 3B together form a flowchart of a process 
for performing circuit simulation at the device level in 
accordance with one embodiment of the invention; 

[0012] FIG. 4 is a flowchart of a process that determines the 
configurable elements that are connected to a given configurable 
element of a PLD; and 

[0013] FIGs. 5A-C illustrate the building of a graph that is 
used in simulation in accordance with the processes of FIGs. 3 
and 4. 

DETAILED DESCRIPTION 

[0014] Various embodiments of the present invention are 
described with reference to FPGAs and tools for developing 
runtime reconfiguration applications, such as JBits. Those 
skilled in the art will appreciate that the invention could be 
used to simulate static circuit designs in addition to runtime 
reconf igurable designs, and that the invention in other 
embodiments would be suitable for simulating circuit designs for 
PLDs other than FPGAs . 

[0015] Design of a static circuit implemented in an FPGA which 
interfaces with a reconf igurable logic coprocessor currently 
requires a combination of two distinct design paths, as shown in 
FIG. 1. The first and perhaps most significant portion of the 
effort involves circuit design using traditional CAD tools. The 
design path for these CAD tools typically comprises entering a 
design 101 using a schematic editor or hardware description 
language (HDL) , using a netlister 102 to generate a netlist 103 
for the design, importing the netlist into an FPGA placement and 
routing tool 104, which finally generates a bitstream file 105 of 
configuration data used to configure the FPGA 106. 
[0016] Once the configuration data has been produced, the next 
task is to provide software to interface the processor to the 
FPGA. The user enters user code 107, which is then compiled 
using compiler 108 to produce executable code 109. The 
instructions in executable code 109 are then used by the 
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processor to communicate with the configured FPGA 106. It is 
also known to use executable code 109 to control the 
configuration of FPGA 106 with bitstream file 105. This series 
of tasks is usually completely decoupled from the task of 
designing the circuit and hence can be difficult and error-prone. 
[0017] In addition to the problems of interfacing the hardware 
and software in this environment, there is also the problem of 
design cycle time. Any change to the circuit design requires a 
complete pass through the hardware design tool chain (101-106 in 
FIG. 1) . This process time is time consuming, with the place and 
route portion of the chain typically taking several hours to 
complete . 

[0018] Finally, this approach provides no support for runtime 
reconfiguration. The traditional hardware design tools provide 
support almost exclusively for static design. It is difficult to 
imagine constructs to support runtime reconfiguration in 
environments based on schematic or HDL design entry. 

[0019] Simulator 12 0 is conventional software that simulates 
operation of a circuit based on a static design set forth in HDL 
101. The simulator is coupled to the netlister and place and 
route software. It will be appreciated that the simulation 
performed by simulator 120 occurs prior to generation of 
bitstream 105. Thus, if errors are introduced in generating the 
bitstream, these errors may go undetected by the simulator. In 
addition, since the design embodied in HDL 101 is static and 
simulator 120 is designed for simulation of static circuits, 
simulation of runtime reconf igurable circuits is not supported. 

[0020] FIG. 2 is a functional block diagram of a system 200 
that illustrates a device simulator in combination with an 
environment for runtime reconf igurable PLD circuit designs. 
System 200 includes a user application program 204 that is 
written in the Java® language, for example. The application 
program 2 04 may be written to perform various functions relative 
to the environment in which system 200 is used. For example, in 
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addition to configuration and/or runtime reconfiguration of FPGA 
202, the user application program 204 may be programmed to 
provide user-interface functions and/or digital signal 
processing. 

[0021] Core library 206 is a collection of macrocell or "core" 
generators that are implemented as Java classes. The cores are 
generally parameterizable and relocatable within a device. 
Examples of cores include counters, adders, multipliers, constant 
adders, constant multipliers, flip-flops and other standard logic 
and computation functions. 

[0022] Bit-level interface 208 includes an application program 
interface that allows the user application program 2 04 to 
manipulate configurable resources of FPGA 202. The bit-level 
interface also includes a set of functions, one or more of which 
are invoked when the user application program 204 references the 
application program interface. The set of functions in the bit- 
level interface manipulate selected ones of programming bits 210, 
based on the type of FPGA. JBits software from Xilinx is an 
example development/execution environment. While core library 
206, user application 204, and bit-level interface 208 are 
written in Java in the example embodiment, it will be appreciated 
that many other languages would also be suitable. 

[0023] The programming bits are stored in storage element 212. 
Storage element 212 may be magnetic, optical, electronic, or a 
suitable combination thereof that is readable and writable. To 
configure FPGA 202, user application 204 uses selected ones of 
bit-level interface routines 2 08 to read the programming bits 210 
and generate a configuration bitstream. In conjunction 
therewith, selected routines of the hardware interface 214 are 
invoked to load the configuration bitstream into the FPGA 202. 
[0024] Hardware interface 214 includes a portable layer of 
software and accompanying hardware to couple application program 
204 to FPGA 202. For example, hardware interface 214 may be the 
Xilinx Hardware Interface (XHWIF) which is available from XILINX. 
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[0025] Processor 216 is coupled to FPGA 2 02 via hardware 
interface 214. The functional requirements of system 200 dictate 
the particular style and capabilities of processor 216. For 
example, some applications may call for a RISC based processor 
while others may call for a CISC. Various ones of special 
purpose or general purpose processors from manufacturers such as 
Intel, Sun Microsystems, Motorola, IBM, AMD and others may be 
suitable. 

[0026] Device simulator 222 simulates operation of the circuit 
defined by programming bits 210 as implemented on FPGA 202. The 
device simulator is coupled to bit-level interface 208 and to the 
hardware interface 214. Since the device simulator performs the 
simulation based on the programming bits 210 and uses the same 
hardware interface 214 as does FPGA 2 02, simulation of runtime 
reconfigurable applications is supported. In addition, device 
simulator can be implemented in a tool-independent manner. That 
is, since the device simulator has access to a configuration 
bitstream, the device simulator can operate independent of the 
tools used to create the configuration bitstream. Depending on 
implementation requirements, device simulator 222 may be hosted 
on the same processor as user application 204 and bit-level 
interface 208 or on a separate processor. 

[0027] Since device simulator 222 simulates the configurable 
logic elements of FPGA 202, an enhanced level of simulation 
accuracy is provided. Furthermore, configurations that are 
illegal or would cause damage if tested on FPGA 202 can be tested 
with device simulator and corrected without causing damage to the 
hardware . 

[0028] In one embodiment, device simulator 222 invokes 
routines of bit-level interface 2 08 to determine the 
configuration for configurable logic elements of FPGA 202. It 
another embodiment, the device simulator reads a configuration 
bitstream to determine the configuration. 

[0029] Device simulator 222 includes routines that interface 
with hardware interface 214. Thus, a user application 2 04 can be 
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run with either FPGA 202 or with device simulator 222. In 
addition, other tools can be used to interface with the device 
simulator. For example, the BoardScope debug tool from Xilinx, 
which conventionally interfaces with an FPGA via hardware 
interface 214, can also be used to interface with device 
simulator 222. Since device simulator 222 implements the device 
interfaces provided by hardware interface 214, tools such as the 
BoardScope tool can be used without modification. 
[0030] Device simulator 222 implements a set of interface 
routines as specified by the hardware interface. For the XHWIF 
interface, the following methods are provided by the device 
simulator : 

[0031] connect () performs a logical link between the user 
application and the device simulator. 

[0032] disconnect () severs the logical link previously created 
with a connect () call. 

[0033] isConnected( ) returns status information about the 
logical link between the user application and the device 
simulator . 

[0034] getNameO returns textual information pertaining to the 
type of simulator and version information. 

[0035] getArraySize ( ) returns the number of FPGA elements 
available to the user for processing. In the case of the 
simulator this is always 1. 

[0036] getDeviceType ( ) returns information pertaining to the 
type of FPGA elements available. 

[0037] getPackageType ( ) returns information about the FPGA 
packaging arrangement . 

[0038] getSystemlnf o ( ) returns additional system information 
that is hardware specific. In the case of the device simulator, 
a null is returned. 

[0039] reset () forces a reset on all devices. 

[0040] setClockFrequency () sets the free running clock 

frequency. 
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[0041] 



clockOn() puts the clock in free running mode. 



[0046] 



[0042] 



[0043] 



[0044] 



[0045] 



clockOff () puts the clock in single stepping mode. 
clockStepO single or multi-steps the clock. 
getConf iguration ( ) reads data from an FPGA device. 
setConf iguration ( ) sends data to an FPGA device. 
getRAMO reads data from an SRAM on a board. The 



device simulator returns nulls for this call. 



[0047] setRAMO sends data to an SRAM on a board. The device 

simulator performs no action for this call. 

[0048] The reset (), clockStepO, getConf iguration, and 

setConf iguration methods are further described below. 

[0049] A user application (204, FIG. 2) can access the 



hardware interface routines to interact with device (e.g., FPGA 
2 02) or with a device simulator. In one embodiment, the user 
application provides to the connect routine an input parameter 
that references either a device or the device simulator. Thus, 
via startup parameters that are provided as input to the user 
application, the user application can run in either in a 
simulation mode or with an actual device. 

[0050] FIGs. 3A and 3B together contain a flowchart of a 
process for performing circuit simulation at the device level in 
accordance with one embodiment of the invention. The process 
generally entails modeling the behavior of configurable elements 
of a programmable logic device by generating and processing 
events as set forth in a configuration bitstream. 
[0051] At step 302, the current clock cycle is initialized to 
0 and any objects that were created in prior iterations of the 
process have the input and output logic levels set to 0. The 
objects represent configurable elements of the PLD. For example, 
in an FPGA, the programmable logic elements include flip-flops 
(FFs) and lookup tables (LUTs) . In the example embodiment, an 
object is instantiated when a change in state of another object 
is traced as an input signal to the new object. 

[0052] At step 3 04, the process waits for a hardware interface 
method to be called. If the reset method is called, the process 
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returns to step 3 02 to reset the current clock period and 
input/output logic levels of the objects. The event queues, 
which are described below, are also cleared at step 3 02. 
[0053] If the getConf iguration ( ) method is called, control is 
directed to step 3 06 where the readback function for an FPGA, for 
example, is performed on the objects. The state data of the 
objects are returned to the hardware interface in the same format 
as a physical device would provide. Control is then returned to 
step 302. 

[0054] If the setConf iguration ( ) method is called, the process 
is directed to step 308. At step 308, the configuration 
bitstream is parsed to determine which configurable elements of 
the device are to change state from logic level 0 to 1 or 1 to 0. 
Selected objects and events are generated at step 310. For a 
configurable logic element for which an object has not yet been 
created, the initial logic level is assumed to be 0, and no 
object or event is generated if the logic level of the in the 
configuration bitstream of the element is 0 since there is not a 
change in state. Since objects represent configurable logic 
elements of a PLD, the term "object" may sometimes be used when 
referring to a configurable logic element. 

[0055] Each object includes the following attributes: a logic 
state value for each input pin of the associated configurable 
element, and timestamps associated with the input pin attributes. 
In addition, a LUT object includes a bit-string attribute that is 
addressable by the combination of logic state values of the input 
pins, and both LUT and FF objects include a current output state 
value . 

[0056] Events are created for each of the objects that 
undergoes a change in state. In the example embodiment, an event 
includes five attributes. One attribute is the object with which 
the event is associated. For example, if the object is a FF, the 
device-relative identifier of the FF is included in the event. 
The second attribute identifies an input pin of the object. It 
will be appreciated that an event for a FF has only one input pin 
while a LUT has multiple input pins. The third attribute 
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indicates the state of the identified input pin. The fourth 
attribute is a timestamp that indicates the simulation relative 
time at which the event was generated. The fifth attribute is a 
delay value that describes the routing delay. 

[0057] Routing delay is defined by the worst case time taken 
for a source state change to reach and affect a corresponding 
input sink (including fanout) . The routing delays are used to 
determine timing violations and the clock cycle with which to 
associate the event. 

[0058] In another embodiment, events also include timing delay 
values. In performing a simulation, the delay for a given signal 
can be calculated based on the delays associated with the events 
that are generated and processed in the simulation. 
[0059] The bit value in the bit-string attribute as indexed by 
the logic state values of the input pins provides the current 
output state of a LUT. Since a LUT may represent a multi-gate 
function of the high-level design, the device level simulator is 
more efficient than a gate-level simulator. In other words, 
instead of simulating multiple gates (requiring multiple events), 
the device level simulator packs the combined function of 
multiple gates into a LUT and simulates the LUT (requiring a 
single event) . 

[0060] The objects created in step 310 are added as nodes to a 
graph (e.g., FIGs. 5A-B) . Arcs are added to the graph to connect 
the nodes when events are processed. Each arc represents a 
source-to-sink coupling of the objects represented by the nodes. 
[0061] At step 312, the events that were created at step 310 
are added either to a synchronous event queue or an asynchronous 
event queue. A synchronous event is defined as an event 
generated for an object that will change output state on the next 
clock edge in response to the input signal of the event. For 
example, a synchronous event is generated for a data input signal 
to a FF, An asynchronous event is defined as an event generated 
for an object that will change output state immediately in 
response to the input signal of the event. For example, if the 
output signal of a FF is used to drive the clock-enable signal of 
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another FF, an asynchronous event is generated. LOT input signals 
are also asynchronous. 

[0062] An asynchronous and a synchronous queue are maintained 
for each clock cycle. Whenever an event is generated, the 
accumulated delay (or timestamp) of the event is checked along 
with the type of the event. For example, an asynchronous event 
will be put in the current asynchronous queue as long as its 
accumulated delay (or timestamp) does not exceed the current 
clock period. If the accumulated delay exceeds the current clock 
period, the event is put in the asynchronous queue of the next 
clock period and a timing violation is flagged. In the case of a 
synchronous event, if the accumulated delay (or timestamp) for 
the event is less than the current clock period, the event is put 
in the synchronous queue of the next clock period (current clock 
period + 1) . For example, the event associated with a data input 
to a flip flop is put on the synchronous queue for the next clock 
period, since the flip flop will not change state during the 
current clock period. If the accumulated delay of the 
synchronous event is greater than the current clock period, the 
event is put in the synchronous queue of the clock period after 
the next clock period (current clock period + 2), and a timing 
violation is flagged. 

[0063] Following step 312, the process continues at decision 
step 314 of FIG. 3B, as shown by path 312p. 

[0064] Events in the synchronous queue of a clock cycle are 
processed before events in the asynchronous queue of the same 
clock cycle. Decision step 314 tests whether the synchronous 
queue of the current clock cycle is empty and directs control to 
step 316 if there is a synchronous event to process. In one 
embodiment, the synchronous and asynchronous event queues are 
maintained is a last-in-first-out (LIFO) order. Maintaining the 
event queues in this manner eliminates sorting of the events by 
timestamps and allows the simulation to skip unnecessary 
processing of earlier events that are intermediate states of a 
signal . 
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[0065] At step 316, an event is removed from the synchronous 
event queue, and the process proceeds to decision step 318. 
Decision step 318 compares the times tamp of the event to the 
timestamp associated with the input pin of the object. If the 
timestamp of the event is prior to the timestamp of the input pin 
of the object, the event can be discarded as shown by step 320. 
The process then continues at decision step 312 as described 
above . 

[0066] If the event cannot be discarded, the process is 
directed to step 322. At step 322, the value of the input pin 
from the current event, along with the timestamp of the current 
event, are used to update the corresponding attributes of the 
object referenced by the event (e.g., the timestamp of the input 
pin) . In addition, the output state value of the object is 
updated as a function of the value of the input pin from the 
event . 

[0067] The process continues to decision step 324 to test 
whether the output state value of the object referenced by the 
event changed in response to the event. If no change in output 
state occurs, the process returns to decision step 312. 
Otherwise, the process continues at step 326. 
[0068] At step 32 6, the one or more configurable logic 
elements that are connected to the output pins of the 
configurable logic element of the object of the current event 
("current object") are identified. FIG. 4 illustrates an example 
process for tracing the connections . 

[0069] After the elements are identified, step 328 generates 
events for each of the objects from step 32 6 and calculates 
current delay values for each of the events . The current delay 
value for an event is the timestamp of the source event (event 
from step 316) plus the routing delay value assigned to the arc 
that connects the current object to the object associated with 
the newly generated event . 

[0070] Decision step 330 checks for timing violations by the 
events by comparing the current delay values to the current clock 
period. For events having current delay values greater than the 
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current clock period, control is directed to step 332 where a 
timing violation is reported to the user. Where the current 
delay value is greater than the current clock period, the 
asynchronous or synchronous event is put on a different clock 
queue from that required to meet the clock period edge 
requirements. Thus, at step 334, synchronous events are put on 
synchronous event queue of the clock period, CI, where Cl = 
current clock period + 1 + (current delay/current clock period) . 
Asynchronous events are put on the asynchronous event queue of 
the clock period C2, where C2 = current clock period + (current 
delay/current clock period) . The timestamps of the new events 
are set to 0. The simulation process continues and performs as 
the hardware would with the event not being processed until a 
subsequent clock cycle. 

[0071] For events having current delay values less than or 
equal to the current clock period, decision step 330 directs 
control to step 336. At step 336, the synchronous events are put 
on the synchronous event queue for the clock period Cl, where Cl 
= current clock period + 1; asynchronous events are put on the 
asynchronous event queue for the clock period C2, where C2 = 
current clock period. For asynchronous events, the timestamps 
are set to the current delay value, and for synchronous events, 
the timestamps are set to 0. 

[0072] After steps 334 and 336, control is returned to 
decision step 312. When the synchronous event queue for the 
current clock period is empty, the process is directed to 
decision step 338 to check the asynchronous event queue of the 
current clock period. If there is an asynchronous event, step 
340 removes the event from the queue and directs the process to 
decision step 318 as described above. Once both the synchronous 
and asynchronous event queues of the current clock period are 
empty, the process is directed to step 342 where the current 
clock period is incremented. The process then returns to step 
304 of FIG. 3A via path 342p. 



13 



X-786 US 



PATENT 



[0073] FIG. 4 is a flowchart of a process that determines the 
configurable elements that are connected to a given configurable 
logic element of a PLD. The process generally entails 
maintaining a graph where the objects that represent configurable 
logic elements are nodes in the graphs, and arcs between the 
nodes represent source-to-sink connections between the objects. 
[0074] At decision step 402, the process checks the graph to 
determine whether the current object has output connections to 
other objects in the graph. If so, the process is directed to 
step 404, where the one or more objects to which the current 
object is connected are returned to the simulation process of 
FIG. 3. Otherwise, the process is directed to step 406. 
[0075] At step 406, the process determines which configurable 
elements of the PLD have input pins connected to the output pins 
of the current object. In one embodiment, the connection 
information is available in a routing database that is accessible 
via JRoute routines of the aforementioned JBits software. Those 
skilled in the art will appreciate that in another embodiment, 
such as simulating static circuit designs, place-and-route tools 
can be used to determine the connections between configurable 
logic elements. 

[0076] In the example embodiment, the device simulator in 
processing an event traces connections to configurable logic 
elements that are connected to the current object, rather than 
establishing a graph of all objects at initialization. This 
method spreads the computation cost of tracing all the objects 
over the entire simulation instead of incurring the entire cost 
at initialization. In an alternative embodiment, the connections 
could be traced at initialization. 

[0077] Step 406 also determines the routing delay values for 
the connections between the current object and the connected 
configurable logic elements. The routing delay values are 
determined by accumulating the delay introduced by the routing 
resources used by the source to get to the sink, including 
fanout. The resistance and capacitance effects of each routing 
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resources are also calculated and incorporated into the routing 
delay values . 

[0078] At step 408, objects are created for any configurable 
elements that were identified in step 406 and that do not have a 
corresponding object. At step 412, the newly created objects are 
added to the graph, and at step 414 arcs are added to the graph 
to connect the current object to the newly created objects. The 
routing delay values from step 406 are assigned to the arcs at 
step 416 to represent the delay associated with the connections. 
The process then proceeds to step 404 as described above. 

[0079] FIGs. 5A-C illustrate the building of a graph that is 
used in simulation in accordance with the processes of FIGs. 3A-B 
and 4. FIG. 5A illustrates graph 500 that includes LUTs 502, 
504, 506, and 508. Events are associated with the LUTs and are 
present in the asynchronous event queue (not shown) for the 
current clock period. Assuming that there are no events in the 
synchronous queue for the current clock period, the event 
associated with LUT 502 is processed first. If the LUT 502 event 
causes LUT 502 to change state, FF 510 (FIG. 5B) is identified as 
being connected to LUT 502, and a synchronous event is generated 
for FF 510. The event for FF 510 is assigned a current delay 
value = timestamp of event for LUT 502 plus the routing delay 
value assigned to the arc that connects LUT 502 to FF 510. 
Assuming this current delay value is less than the current clock 
period, an event is generated for FF 510 and put in the 
synchronous queue for the current clock period + 1 . 
[0080] Since there are still no synchronous events for the 
current clock period, the next asynchronous event for the current 
clock period is processed. The LUT 504 event is processed in a 
manner similar to the processing of the LUT 502 event as 
described above. An object is created for LUT 514 (FIG. 5B) and 
a synchronous event for FF 514 is put in the synchronous queue 
for the current clock period +1. An asynchronous event for LUT 
506 is processed in a comparable manner, with an object generated 
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for FF 518 and an event for FF 518 put in the synchronous queue 
of the current clock period + 1, 

[0081] The asynchronous event for LUT 508 is processed next, 
resulting in an asynchronous event for LUT 516. If the new 
current delay value is less than the current clock period, the 
event for LUT 516 is put in the asynchronous queue of the current 
clock period. Since the event for LUT 516 is now on the 
asynchronous queue of the current clock period, the LUT 516 is 
processed next. Assuming the LUT 516 event causes LUT 516 to 
change state, FF 520 is identified as being connected to LUT 516, 
a synchronous event is generated for FF 520, and a current delay 
value is calculated for the FF 520 event. Assuming that the 
current delay value is less than the current clock period, the FF 
52 0 event is put in the synchronous queue for the next clock 
period (current clock period + 1) . 

[0082] With the event queues of current clock period now 
empty, the current clock period is incremented to the next clock 
period. At this juncture, graph 500 of FIG. 5B illustrates the 
current objects, and the current clock period has 4 events on the 
synchronous queue and 0 events on the asynchronous queue. The 
process continues when a clockStepO method is called from the 
hardware interface . 

[0083] The first event processed from the synchronous event 
queue is the FF 520 event. Events are generated as described 
above for objects (not shown) that are connected to the output 
pin of FF 520. The FF 518 event is processed next, resulting in 
a change in the output state. This causes events to be generated 
for LUTs 512 and 516 (FIG. 5C) . The timestamps for the 
synchronous events are reset to 0. Thus, the new current delay 
values are equal to the routing delay values of each of the arcs 
from FF 518 to LUTs 512 and 516. If there are no timing 
violations, the two events are put in the asynchronous queue of 
the current clock period. The process then continues under the 
control of the called hardware interface methods. 
[0084] The present invention is believed to be applicable to a 
variety of environments for simulation of designs for PLDs and 
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has been found to be particularly applicable and beneficial in 
simulating runtime reconf igurable PLD circuit designs. Other 
aspects and embodiments of the present invention will be apparent 
to those skilled in the art from consideration of the 
specification and practice of the invention disclosed herein. It 
is intended that the specification and illustrated embodiments be 
considered as examples only, with a true scope and spirit of the 
invention being indicated by the following claims. 
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